<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <script src="../js/vue.js"></script>
    <title></title>
</head>
<body>
<script type="text/javascript">
    let number = 18
    let person = {
        name: "张三",
        sex: "男"
    }
    // 给person对象添加一个属性
    Object.defineProperty(person,'age',{
        // value: 20,
        // 控制属性是否可以被枚举，默认为false
        // enumerable: true,
        // 控制属性是否可以被修改，默认为false 
        // writable: true,
        // 控制属性是否可以被删除，默认为false
        // configurable: true,
        // 当读取person的age属性时，getter会被调用，且返回值就是age的值
        get(){
            console.log("调用了gettter")
            return number
        },
        // 当修改person的age属性时，setter就会被调用，且会收到修改的具体值
        set(value){
            console.log("调用了setter，且值为",value)
            number = value
        }
    })
</script>
</body>
</html>